WO 01/16758

Applicant(s): Gilbert Wolrich et al.

DOUBLE SHIFT INSTRUCTION FOR MICRO ENGINE USED IN MULTITHREADED PARALLEL PROCESSOR ARCHITECTURE

PCT/US00/23982

1/5

10

Page 1



WO 01/16758

1 11

. Eddi

Matter N 1559-302US1 Page 2
Applicant(s): Gilbert Wolrich et al.
DOUBLE SHIFT INSTRUCTION FOR MICRO ENGINE USED IN MULTITHREADED PARALLEL PROCESSOR ARCHITECTURE

CT/US00/23982

2/5



Matter No.: 10559-302US1 Applicant(s): Gilbert Wolrich et al.

Page 3 of 5

WO 01/16758

DOUBLE SHIFT INSTRUCTION FOR MICRO ENGINE USED IN MULTITHREADED PARALLEL PROCESSOR

**ARCHITECTURE** 

PCT/US00/23982

3/5



Fig 3

PCT/US00/23982

WO 01/16758

Matter No. 59-302US1 Applicant(s): Gilbert Wolrich et al.

DOUBLE SHIFT INSTRUCTION FOR MICRO ENGINE USED
IN MULTITHREADED PARALLEL PROCESSOR **ARCHITECTURE** 

> Lookup Instructions 82a 82b Form Register File Addresses 82c Fetch Operations 82d ALU Operation

FIG. 4

Write-Back of Results

82e

WO 01/16758

Matter No.: 10559-302US1 Applicant(s): Gilbert Wolrich et al. DOUBLE SHIFT INSTRUCTION FOR MICRO ENGINE USED IN MULTITHREADED PARALLEL PROCESSOR ARCHITECTURE

PCT/US00/23982

| 31 30 29 28 27 26 25 24 23 22 3   | 21 20 19 18 17 16 15 14 13 12 | 11 10 9 8 7 6 5 4 3 2 1                              | 0  |
|-----------------------------------|-------------------------------|------------------------------------------------------|----|
| ALWISHER O O SW shft rel dest reg | descrit is A rel source       | Brel some re in Bi ALU OP                            |    |
| (a ha)                            | 21 20 19 18 17 16 15 14 13 12 |                                                      |    |
| (set 4) 0 0 sw shift rel dest reg |                               |                                                      | ٦  |
| (30. )                            |                               |                                                      |    |
| ALUSH 0 0 sw shot rel dest reg    | amount sel source             | immediate // Alle                                    | ,  |
| 31 30 29 28 27 26 25 24 23 22 3   |                               |                                                      |    |
| ALL 100 dest reg                  |                               | 11 10 9 8 7 6 5 4 3 2 1<br>Lab abs See 40 B Soc Allo | ۳. |
| (Rtcc)                            |                               | 7.20                                                 |    |

## Shift Decode:

(rs, r0) decode ([31:0] shifts into [63:32] and take [63:32]):

00 = left rotate

01 = right shift (32-ShfAmt = Right Shft Amt)

10 = left shift

11 = double shift (upper A-op shifts into lower B-op)

===> "left rotate" of zero gives zero shift (therwise zero amount signifies indirect shift)

## ALU-OP decode:

| 0000 = B           | 0100 = ~A&B (~and) | 1000 = A-B | 1100 = A + B(8)  |
|--------------------|--------------------|------------|------------------|
| 0001 = -B          | 0101 = XOR         | 1001 = B-A | 1101 = A + B(16) |
| 0010 = A&B (and)   | 0110 = OR          | 1010 =     | 1110 = A+B       |
| 0011 = A&~B (and~) | 0111 = mul-stuff   | 1011 =     | 1111 = A+B+Cin   |

FIG. 5